# RH

### INTERRUPTIVE PROCESSING DECENTRALIZATION SYSTEM

Patent number:

JP7244649

**Publication date:** 

1995-09-19

Inventor:

SAITO HIROYUKI

Applicant:

**FUJITSU LTD** 

Classification:

- international:

G06F15/163; G06F9/46

- european:

**Application number:** 

JP19940036660 19940308

Priority number(s):

#### Abstract of JP7244649

PURPOSE:To decentralize the load on a device of loosely coupled type multiprocessor constitution by preventing interruptive processing from being concentrated on a specific processor.

CONSTITUTION: The device of loosely coupled type multiprocessor constitution obtained by connecting plural CPU boards 1, on which CPUs 11 are mounted, to a common bus 3 in parallel, is provided with queue counters 15 at interruptive processing parts on the respective CPU boards 1 to count queues of interrupts to the CPU boards 11; and interruption transmission control parts 16 are provided to control whether or not interrupts from the common bus are sent to the CPUs 11 according to the counting results of the interrupt queues, thereby transmitting the interrupts to the CPUs 11 only when the number of interrupts from the common bus is large.



Data supplied from the esp@cenet database - Worldwide

#### (19)日本国特許庁 (JP)

## (12) 公開特許公報(A)

#### (11)特許出願公開番号

## 特開平7-244649

(43)公開日 平成7年(1995)9月19日

(51) Int.Cl.6

識別記号

庁内整理番号

FΙ

技術表示箇所

G06F 15/163

9/46

360 A 7737-5B

G06F 15/16

310 Q

審査請求 未請求 請求項の数10 OL (全 12 頁)

(21)出願番号

(22)出願日

特願平6-36660

平成6年(1994)3月8日

(71)出顧人 000005223

富士通株式会社

神奈川県川崎市中原区上小田中1015番地

(72)発明者 齋藤 宏行

神奈川県川崎市中原区上小田中1015番地

富士通株式会社内

(74)代理人 弁理士 柏谷 昭司 (外1名)

#### (54)【発明の名称】 割込処理分散方式

#### (57) 【要約】

【目的】疎結合型のマルチプロセッサ構成をとる装置に おいて、特定のプロセッサに割込処理が集中することを 防止して、負荷の分散を図ることを目的とする。

【構成】 CPU11を搭載した複数のCPUボードを並 列に共通バス3に接続してなる疎結合型のマルチプロセ ッサ構成の装置において、各CPUボードにおける割込 処理部分に、キュー・カウンタ15を設けて、CPUに 対する割込キューを計数し、割込伝達制御部16を設け て、割込キューの計数結果に応じて共通バスからの割込 をCPUに伝達するか否かを制御することによって、共 通バスからの割込数が多いときのみCPUに割込を伝達 するように構成する。

#### 本発明の原理的構成(1)を示す図



1

#### 【特許請求の範囲】

【請求項1】 CPU (11)を搭載した複数のCPU ボードを並列に接続してなる疎結合型のマルチプロセッサ構成の装置において、各CPUボードにおける割込処理部分に、

該 C P U に対する割込キューを計数するキュー・カウンタ (15) と、

該割込キューの計数結果に応じてCPUへの割込の伝達 を制御する割込伝達制御部(16)とを設けて、

共通バス (3) からの割込数が多いときのみCPUに割 10 込を伝達するようにしたことを特徴とする割込処理分散 方式。

【請求項2】 前記割込伝達制御部(16)が、共通バス(3)からの割込を計数し、該割込の計数値と前記割込キューの計数値とを比較して、共通バスからの割込数が多いとき、割込をCPUに伝達することを特徴とする請求項1に記載の割込処理分散方式。

【請求項3】 前記割込伝達制御部(16)が、定常的にサイクリックに一定値をカウントするカウンタ(27)の計数値と前記割込キューの計数値とを比較して、該カウンタの計数値が多いとき、割込をCPUに伝達することを特徴とする請求項1に記載の割込処理分散方式。

【請求項4】 前記割込伝達制御部(16)が、定常的にサイクリックに一定値をカウントするカウンタ(27)の計数値と前記割込キューの計数値とをアドレスとしてROM(28)に格納されている値を読み出し、該読み出された値に応じて割込をCPUに伝達するウィンドウ時間を制御することを特徴とする請求項1に記載の割込処理分散方式。

【請求項5】 前記割込伝達制御部(16)が、定常的にサイクリックに一定値をカウントするカウンタ(27)の計数値と前記割込キューの計数値とをアドレスとして、装置の動作状況に対応して予めマッピングされているRAM(29)の値を読み出し、該読み出された値に応じて割込をCPUに伝達するウィンドウ時間を制御することを特徴とする請求項1に記載の割込処理分散方式。

【請求項6】 CPU(11)を搭載した複数のCPU ボードを並列に接続してなる疎結合型のマルチプロセッ 40 サ構成の装置において、各CPUボードにおける割込処 理部分に、

該CPUに対する割込の制御と、ベクターのプリフェッチとを行う割込/ベクター・プリフェッチ制御部 (17)を設けて、

共通バス (3) からの割込入力時、バス調停を起動してバス権を得たとき割込元のベクターをラッチ (18) にプリフェッチし、CPUが割込を受け付けてスタック・フレームの退避等の処理を終了したとき該プリフェッチされたベクターを取り込んで割込処理を起動するように 50

2

したことを特徴とする割込処理分散方式。

【請求項7】 前記割込/ベクター・プリフェッチ制御部(17)がCPU(11)に内蔵されていることを特徴とする請求項6に記載の割込処理分散方式。

【請求項8】 前記割込/ベクター・プリフェッチ制御部(17)がCPUおよび割込処理部分に対する割込信号の中継をオン/オフするラッチ(31)を有し、該CPUがホルト状態にないとき該ラッチ(31)を開いて割込信号を中継することを特徴とする請求項6または7に記載の割込処理分散方式。

【請求項9】 前記割込/ベクター・プリフェッチ制御部 (17) がCPUおよび割込処理部分に対する割込信号の中継をオン/オフするラッチ (31) を有し、前記ラッチ (18) にベクターをラッチしてCPUが割込処理を開始したとき該ラッチ (31) をオフにし、該割込処理を終了したとき該ラッチ (31) をオンにすることを特徴とする請求項6または7に記載の割込処理分散方式。

【請求項10】 前記割込/ベクター・プリフェッチ制御部(17)がCPUに対する割込信号の中継をオン/オフするバッファ(40)を有し、前記ラッチ(18)に有効なベクターがラッチされたとき該バッファ(40)をオンにしてCPUに割込信号を入力し、該CPUがスタック・フレームの退避等の処理を終了してベクター要求を発生したとき該ラッチ(18)内のベクターをCPUに通知することを特徴とする請求項6または7に記載の割込処理分散方式。

#### 【発明の詳細な説明】

[0001]

【産業上の利用分野】本発明は、疎結合型のマルチプロセッサ構成をとる装置において、特定のプロセッサに割込処理が集中することを防止して負荷を均等化するための、割込処理分散方式に関するものである。

【0002】疎結合型のマルチプロセッサ構成をとる装置においては、共通バスを介して結合された複数のマルチプロセッサが、それぞれ独自に有するプログラムに基づいて独立に動作することができる。例えば疎結合型のマルチプロセッサ構成をとる無線通信用各種制御装置等においては、装置の状態変化や外部との通信等が非同期で発生するが、これに対する処理要求を並列に接続された各中央処理装置(CPU)に通知するために、共通バスを介して、各CPUに割込を通知することによって、割込に応答したCPUが所要の処理を行うようになっている

【0003】この場合、各CPUが負荷を平等に分担することによって、過負荷がかかった場合でも、装置として最大の能力を発揮することができる。そのため、共通バスから入力される割込を、各CPUができるだけ均等に受け取るようにする必要がある。

【0004】このことは、システム構成の変化等によっ

3

て、装置の能力アップを図ろうとする場合には、並列に接続されるCPUの数を増加するだけで、簡易に対処可能にするためにも、必要なことである。

【0005】また上記の装置では、スレーブの入出力 (I/O)盤から発生する割込を、各CPUに均等に処理させることによって、各CPUに加わる負荷を均等に分散させている。従って各CPUが割込に応答し、その割込処理を起動するためのベクターを、共通バス上のスレーブのI/Oボート等から均等に獲得するようにすることが必要である。

#### [0006]

【0007】図11において、各CPUボードのCPUには、割込バス5から割込(IRQ)が並列に入力されている。各CPUは割込を受け付けたとき、スタック・フレームの退避等を行って割込処理を起動すると、バス調停部13に共通バス獲得要求を出す。そしてバス調停の結果バス権を得たCPUは、割込元のI/Oボードから割込ベクター番号を受けとって、所定の割込要因処理タスクをキューとして積んで、割込処理からぬける。

【0008】割込要因処理タスクの順番は、OS (Oper ation System) によって管理実行され、順次、割込要因 30 処理タスクが起動されて、受信電文の引取りや、状態変化の認識処理等が行われる。割込処理中は割込がマスクされて、他の割込が共通バスから入力されても、CPU は認識することができない。

【0009】またI/Oボード2からの割込は、共通バス3を介して各CPUボードに入力され、それぞれのCPUボードは、次のような処理フローに従って、ベクターをフェッチする。

### [0010]

1

① 現在実行中の命令を終了する。・・

プロセッサの内部状態をスタック・フレームに退避・・ する。

③ ベクター・フェッチのため、共通バス要求を起動す・・る。

④ ベクターをフェッチし、割込処理を起動する。ただ・・ しこの処理は共通バス調停の結果バス権を得たCPUの みであって、他のCPUは無効割込処理を起動する。 5 4

【0011】従って、各CPUに同じソフトウェアが搭載してあっても、その動作の同期がとれている訳ではないので、同時に割込が入力されても、各CPUがベクターをフェッチしにゆくまでの時間には、ばらつきがある。

#### [0012]

【発明が解決しようとする課題】CPUが割込信号を認識して、スタック退避等を行って割込処理を起動するのは、割込信号が入力されたときに実行中であった命令群を終了してからになるので、各CPUがプログラムのどの部分を走行していたかによって、実行中の命令が異なることとなり、割込信号が各CPUに同時に並列に入力されても、割込処理が起動されるまでの時間は、各CPUが実行中の命令によって異なる。

【0013】そこで、プログラムによっては、割込処理 後に走行する部分の命令群のクロック数が少ないことが あって、割込に反応しやすくなるため、ある特定のCP Uが割込を多くとるようになり、割込処理のキューを多 数積んで負荷が集中する現象を生じて、負荷分散の観点 から問題となっていた。

【0014】また、クロック数が少ない命令を実行している場合には、処理時間が比較的短くてすむため、ソフトウェアの構造によっては、ある一つのCPUのベクター・フェッチ動作が速くなる。これは、割込ハンドラーの部分を、少ないクロック数の命令で構成した場合等に生じる。そのため、そのCPUが割込処理を多数獲得してしまうことがあって、負荷分散の観点から問題となっていた。

【0015】本発明は、このような従来技術の課題を解決しようとするものであって、疏結合型のマルチプロセッサ構成をとる装置において、各CPUがプログラムのどの部分を走行していても、ある特定のCPUに割込が集中することを防止して、より負荷が軽いCPUに割込がかかりやすくし、従って負荷の均等分散が可能になるようにすることを目的としている。

【0016】また本発明は、CPUに搭載されているプログラムの構造のいかんにかかわらず、各CPUが均等にベクターをフェッチするようにして、割込処理が各CPUにおいて均等に起動され、従って、負荷の分散が可能になるようにすることを目的としている。

#### [0017]

【課題を解決するための手段】図1は、本発明の原理的構成(1)を示したものであって、図11におけると同じものを同じ番号で示している。CPUボード1において、15は割込要因処理タスクのキューをカウントするキュー・カウンタ、16はキュー・カウンタ値に応じて割込信号をCPU11に伝達する時間または数を制限制御する割込伝達制御部である。

【0018】キュー・カウンタ15は、割込要因処理タ 50 スクのキューの発生または消滅に応じて、CPU11に よってカウントアップまたはカウントダウンするように制御される。割込伝達制御部16は、キュー・カウンタ15のカウント値に応じて、共通バス3から入力される割込信号を、CPU11に伝達する時間、または数を制限するように制御する。

【0019】図1において、キュー・カウンタ15は、CPU11が割込処理を起動し、割込要因処理タスクをキューに積んだときカウントアップし、割込要因処理タスクが起動し、処理が完了したとき、カウントダウンするように制御する。従って、キュー・カウンタ15には、現在積まれているキューの数がカウントされている。

【0020】割込伝達制御部16は、キュー・カウンタ15のカウント値に応じて、共通バス3から入力される割込信号を、CPU11に伝達する数、または時間を制限するように制御する。すなわち、キュー・カウンタ15の値が大きくなるに従って、CPU11に通知する割込数を少なくしてキューを減少させる。または、キュー・カウンタ15の値が大きくなるに従って、CPU11に通知する割込のディレー時間を大きくして、割込処理20が起動するのに要する時間を長くしてキューを減少させる。

【0021】図2は、本発明の原理的構成(2)を示したものであって、図11におけると同じものを同じ番号で示している。CPUボード1において、17は割込の受付けと、ベクター・フェッチの制御を行う割込/ベクター・プリフェッチ制御部、18はベクターをプリフェッチするラッチ、19はCPUのローカル・バスである。

【0022】割込/ベクター・プリフェッチ制御部17 30 は、ローカル・バス19と共通バス3に接続されているとともに、共通バス3からの割込信号や、CPU11からの割込信号/割込制御信号等も接続されている。

【0023】割込/ベクター・プリフェッチ制御部17は、共通バス3からの割込信号の入力から一定時間後に共通バス要求を出力し、割込元のI/Oボード等からベクター番号をプリフェッチする。割込の入力に同期して、一定時間後に、各CPUが一斉に共通バス要求を出力すると、各CPUの割込/ベクター・プリフェッチ制御部17には、均等に割込ベクターがプリフェッチされ40る。各CPUは、割込信号によって、割込ベクター要求を発生するので、割込/ベクター・プリフェッチ制御部17から、さきにプリフェッチしているベクターをCPUに渡すことによって、割込処理が起動される。

【0024】図2において、割込/ベクター・プリフェッチ制御部17には、まず共通バス3からの割込信号が入力される。CPU11は割込を受付け可能であるときは、割込信号が入力されてから、一定時間後に共通バス要求を出力し、バス調停を起動して共通バス3が獲得できた場合は、割込元のI/Oボード等からベクター番号50

6

をプリフェッチする。共通バス3が獲得できなかった場合は、無効割込とする。

【0025】ここで、バス調停方式は、各CPUに均等に共通バス獲得権が与えられているものとすると、割込が入力されたのに同期して、一定時間後に各CPUがベクター・プリフェッチのために、一斉に共通バス要求を出力することになるので、各CPUの割込/ベクター・プリフェッチ制御部17には、均等に割込ベクターがプリフェッチされる。

【0026】また同時に、各CPUの割込/ベクター・プリフェッチ制御部17は、割込信号をCPU11に中継しているので、CPU11は、実行中の命令が終了すると、内部状態をスタック・フレームに退避して割込ベクター要求を発生する。そこで、先に割込/ベクター・プリフェッチ制御部17にプリフェッチしているベクターをCPU11に渡すことによって、所定の割込処理を起動する。

【0027】従って、各CPUには均等に割込処理が起動されることになるので、負荷の均等分散を実現することができる。

#### [0028]

#### 【作用】

(1) 疎結合型のマルチプロセッサ構成の装置においては、CPU11を搭載した複数のCPUボードが並列に接続されている。この場合、各CPUボードにおける割込処理部分に、キュー・カウンタ15を設けて、CPUに対する割込キューを計数し、割込伝達制御部16を設けて、割込キューの計数結果に応じて割込をCPUに伝達するか否かを制御するように構成して、共通バスからの割込数が多いときのみCPUに割込を伝達するようにする。

【0029】本発明によれば、各CPUがプログラムのどの部分を走行していても、蓄積されているキューの数に応じて、CPUに対する割込の伝達を、ハードウエアによって自律的にコントロールできるので、特定のCPUに割込が集中することがなく、より負荷の軽いCPUに割込がかかりやすくなるので、負荷の均等分散を図ることができる。

【0030】(2) この場合に、割込伝達制御部16が、 共通バスからの割込を計数し、割込の計数値と割込キュ ーの計数値とを比較して、共通バスからの割込数が多い とき、割込をCPUに伝達するようにしてもよい。

【0031】このようにすることによって、割込キュー数が増加するほど、CPUに割込が伝達される数が少なくなり、割込伝達が制限される。従って、割込はより負荷が小さいCPUにかかるようになり、負荷が分散される

【0032】(3) この場合に、割込伝達制御部16が、 定常的にサイクリックに一定値をカウントするカウンタ 27の計数値と割込キューの計数値とを比較して、カウ ンタの計数値が大きいいとき、割込をCPUに伝達する ようにしてもよい。

【0033】このようにすることによって、より負荷が小さいCPUに割込がかかりやすくなり、負荷の分散を図ることができるようになる。

【0034】(4) この場合に、割込伝達制御部16が、 定常的にサイクリックに一定値をカウントするカウンタ 27の計数値と割込キューの計数値とをアドレスとして ROM28に格納されている値を読み出し、読み出され た値に応じて割込をCPUに伝達するウィンドウ時間を 10 制御するようにしてもよい。

【0035】このようにすることによって、割込キューが蓄積するほど、割込をCPUに伝達するウィンドウ時間が短くなるので、他の負荷が小さいCPUが割込をとる確率が高くなり、割込負荷の分散を図ることが可能となる。

【0036】(5) またこの場合に、割込伝達制御部16が、定常的にサイクリックに一定値をカウントするカウンタ27の計数値と割込キューの計数値とをアドレスとして、装置の動作状況に対応して予めマッピングされて20いるRAM29の値を読み出し、読み出された値に応じて割込をCPUに伝達するウィンドウ時間を制御するようにしてもよい。

【0037】この場合、(4) の場合と同様に、割込負荷の分散を図ることが可能であるとともに、アプリケーションプログラムの性能等によって、ウィンドウ時間の設定を変えることができる。

【0038】(6) 疎結合型のマルチプロセッサ構成の装置においては、CPU11を搭載した複数のCPUボードが並列に接続されている。この場合、各CPUボード 30 における割込処理部分に、割込/ベクター・プリフェッチ制御部17を設けて、CPUに対する割込の制御と、ベクターのプリフェッチとを行うように構成して、共通バス3からの割込入力時、バス調停を起動してバス権を得たとき割込元のベクターをラッチ18にプリフェッチし、CPUが割込を受け付けてスタック・フレームの退避等の処理を終了したとき、プリフェッチされたベクターを取り込んで割込処理を起動するようにする。

【0039】本発明によれば、CPUに搭載されているプログラムの構造のいかんにかかわらず、各CPUが均 40 等にベクターをフェッチするようにしたので、割込処理が各CPUにおいて均等に起動され、従って、負荷の完全分散が可能になる。

【0040】(7) この場合、割込/ベクター・プリフェッチ制御部17を、CPU11に内蔵するようにしてもよい。

【0041】(8) これらの場合、割込/ベクター・プリフェッチ制御部17が、CPUおよび割込処理部分に対する割込信号の中継をオン/オフするラッチ31を有し、CPUがホルト状態にないとき、ラッチ31を開い50

8

て割込信号を中継するようにしてもよい。

【0042】このように、割込発生時、ハードウエア処理によって割込をラッチして、共通バス獲得の調停を行うので、バス調停が各プロセッサに均等にバス獲得権が与えられる方式の場合、割り込み発生に同期して、各CPUが同時にバス要求を出すので、各CPUには均等にベクターがプリフェッチされ、各CPUは均等に割込処理を起動することができ、負荷の均等分散を実現することができる。

【0043】(9) これらの場合、割込/ベクター・プリフェッチ制御部17が、CPUおよび割込処理部分に対する割込信号の中継をオン/オフするラッチ31を有し、ラッチ18にベクターをラッチしてCPUが割込処理を開始したとき、ラッチ31をオフにし、割込処理を終了したとき、ラッチ31をオンにするようにしてもよい。

【0044】このようにすることによって、割込が多発した場合には、割込イベントが発生するごとに、バス調停に参加するCPUが減少するので、より厳密に負荷の均等分散を図ることができる。

【0045】(10) またこれらの場合、割込/ベクター・プリフェッチ制御部17がCPUに対する割込信号の中継をオン/オフするバッファ40を有し、ラッチ18に有効なベクターがラッチされたとき、バッファ40をオンにしてCPUに割込信号を入力し、CPUがスタック・フレームの退避等の処理を終了してベクター要求を発生したとき、ラッチ18内のベクターをCPUに通知するようにしてもよい。

【0046】このようにすることによって、CPUに割込信号が通知されて、CPUが内部状態をスタック・フレームに退避してベクター要求を出したときは、必ず有効なベクターをCPUに渡すことができるので、CPUが無効割込処理を行うことがなくなり、CPU動作の性能向上を図ることが可能となる。

#### [0047]

【実施例】図3は、本発明の実施例(1)を示したものであって、CPU11に対する割込処理部分を示し、図1におけると同じものを同じ番号で示している。21はカウント・コントロール・レジスタであって、キューの発生または消滅に応じて、アップクロックまたはダウンクロックを出力する。22はアップ/ダウン・カウンタであって、積まれているキューの数をカウントする。23は割込数カウンタであって、共通バスにおける割込入力数をカウントする。24は、コンパレータであって、アップ/ダウン・カウンタ22のカウント値と、割込数カウンタ23のカウント値とを比較する。25はゲートであって、コンパレータ24の出力に応じて、イネーブルとなりまたはデセーブルとなる。26はオア回路であって、共通バスからの各割込信号の論理和を求める。

【0048】CPU11は、カウント・コントロール・

レジスタ21を介して、割込処理が起動し割込要因処理 タスクをキューに積んだとき、アップ/ダウン・カウン タ22をアップカウントする。また割込要因処理タスタ が起動し処理を完了したとき、ダウンカウントする。従 ってアップ/ダウン・カウンタ22には、積まれている キューの数がカウントされている。

【0049】一方、割込数カウンタ23は、オア回路26を経て共通バスから割込が入力されるごとに、カウンタアップされる。コンパレータ24は、アップ/ダウン・カウンタ22の値(n)と、割込数カウンタ23の値10(m)とを比較して、m>nの場合、ゲート25をイネーブルにして、共通バスからの各割込をCPU11へ通知する。なお、割込数カウンタ23は、CPU11が割込処理を起動すると、割込応答(IACK)信号によってリセットされる。

【0050】従って、キューが蓄積してn個になったとき、CPU11に割込が伝達される数は、1/(n+1)となり、割込伝達が制限される。これによって、より負荷のかかっていないCPUに割込がかけられるようになり、負荷が分散される。

【0051】図4は、本発明の実施例(2)を示したものであって、図3におけると同じものを同じ番号で示し、27は定常的にサイクリックに一定数をカウントアップまたはカウントダウンするカウンタである。

【0052】アップ/ダウン・カウンタ22においては、図3の場合と同様にして、現在蓄積されているキューの数がカウントされる。カウンタ27は、定常的に一定数までカウントアップし、または一定数からカウントダウンを繰り返している。コンパレータ24は、アップ/ダウン・カウンタ22の値(n)と、カウンタ27の30値(m)とを比較して、m>nのとき、ゲート25をイネーブルにして、共通バスからの割込信号をCPU11に伝達する。従って、キューの蓄積数が増加すると、CPU11に割込が通知されるウィンドウ時間が短くなり、CPU11に入力される割込の数が減少する。

【0053】このように、図4に示された実施例では、 より負荷の小さいCPUに割込がかけられやすくなるの で、負荷の分散を図ることが可能となる。

【0054】図5は、本発明の実施例(3)を示したものであって、(a)は回路構成、(b)はリードオンリ 40ーメモリ(ROM)の構成を示している。また図6は、ROMの内容の例を示したものである。図4におけると同じものを同じ番号で示し、28はROMであって、アップ/ダウン・カウンタ22の値と、カウンタ27の値とをアドレスとして出力を発生する。

【0055】アップ/ダウン・カウンタ22においては、図3の場合と同様にして、現在蓄積されているキューの数がカウントされる。カウンタ27は、定常的にカウントアップまたはカウントダウンを繰り返している。ROM28は、図6に示すように、カウンタ27のカウ50

10

ント値を下位アドレス  $(A0\sim An)$  に入力され、アップ/ダウン・カウンタ 22 のカウント値を上位アドレス  $(An+1\sim Am)$  に入力されることによって、単位時間の 1/16 ごとに順次 00 または 01 となる出力 00 を発生する。

【0056】例えば、カウンタ27のカウント値が00であって、アップ/ダウン・カウンタ22のカウント値が00のときは、ROM28の出力Doは、すべての時間01であって、ゲート25は常に開いている。アップ/ダウン・カウンタ22のカウント値が10のときは、ROM28の出力Doは、最初の1/16の時間00であってゲート25が閉じ、以後01となってゲート25が開く。アップ/ダウン・カウンタ22のカウント値が20のときは、ROM28の出力Doは、始めの2つの1/16の時間00であってゲート25が閉じ、以後01となってゲート25が開じ、以後01となってゲート25が開く。カウンタ27の値が00以外の値のときも同様に、ゲート25の開閉の関係を定めることができる。

【0057】このように、ROM28の内部に、図6に示すようなデータを格納しておくことによって、アップ/ダウン・カウンタ22の値が増加(減少)するのに伴って、ゲート25をイネーブルにする期間を減少(増加)させることができる。

【0058】従って図5の実施例によれば、割込キューが蓄積するのに伴って、割込信号をCPU11に対して伝達するウィンドウ時間が短くなり、他の負荷がかかっていないCPUが割込をとる確率が高くなるので、割込負荷の分散を図ることができる。

【0059】図7は、本発明の実施例(4)を示したものであって、(a)は回路構成、(b)はランダムアクセスメモリ(RAM)の構成を示している。図5におけると同じものを同じ番号で示し、29はRAMであって、アップ/ダウン・カウンタ22の値と、カウンタ27の値とをアドレスとして出力を発生する。RAM29には、図6に示されたROM28と同様の内容を予めマッピングされている。30は双方向ゲートであって、立ち上げ時にRAM29の内容を書き込むために、共通バスをRAM29に接続する。

【0060】アップ/ダウン・カウンタ22においては、図3の場合と同様にして、現在蓄積されているキューの数がカウントされる。カウンタ27は、定常的にサイクリックに一定数のカウントアップまたはカウントダウンを繰り返している。RAM29は、カウンタ27のカウント値を下位アドレス( $A0\sim An$ )に入力され、アップ/ダウン・カウンタ22のカウント値を上位アドレス( $An+1\sim Am$ )に入力されることによって、単位時間の1/16ごとに順次00または01となる出力00を発生する。

【0061】CPUボードのイニシアル処理時等において、アプリケーションプログラムの性能等の要件によっ

て、RAM29の内部を予めマッピングしておくことによって、図5の場合と同様に、アップ/ダウン・カウンタ22の値が増加(減少)するのに伴って、ゲート25をイネーブルにする期間を減少(増加)させることができる。

【0062】このように図7の実施例によれば、割込キューが蓄積するのに伴って、割込信号をCPU11に対して伝達するウィンドウ時間が短くなり、従って、他の負荷がかかっていないCPUが割込をとる確率が高くなるので、割込負荷の分散を図ることができる。

【0063】図8は、本発明の実施例(5)を示したものであって、CPU11に対する割込処理部分を示し、図2におけると同じものを同じ番号で示している。図中、31はラッチ、32は割込信号に応じて一定時間後に各種制御信号を出力するタイマ回路、33は共通バス獲得の調停を行うバス調停部、34,35は双方向バッファ、36はローカルバスである。

【0064】CPU11が停止(halt)状態でないとき、すなわち割込処理を正常に行える場合は、ラッチ31を開いて、割込信号をタイマ回路32とCPU11 20に入力する。タイマ回路32は、割込信号が入力されてから、一定時間後、共通バス獲得のため、バスリクェスト(BR)信号をバス調停部33へ送り、バス調停部33は、共通バス獲得の調停を行う。

【0065】共通バスが獲得されたとき、バス調停部33からのバス獲得(WIN)信号に応じて、タイマ回路32は割込制御信号を双方向バッファ34を経て共通バス3へ送出し、これによって割込元のI/Oボード等から、共通バス3を経て送出された割込ベクターを、双方向バッファ35、ローカルバス36を介してラッチ1830に取り込む。このときは、ラッチ31において割込信号もラッチし、CPU11が割込動作を起動して割込ベクター要求を発生した時点で、ラッチを解くものとする。

【0066】そして、CPU11がスタック・フレームへの内部状態の退避等の処理を完了して、ベクターをフェッチできるようになると、割込応答(IACK)信号を送出することによって、さきほどラッチ18に取り込まれたベクターが、ローカルバス36を経てCPU11に通知され、これによって、CPU11における所定の割込処理が起動される。

【0067】なお、共通バス調停時にバス権を獲得できなかったときは、無効割込として、ラッチ18にはベクターがプリフェッチされず、CPU11が割込ベクターを要求したときは、タイマ回路32からバスエラー(BERR)信号等を返すので、CPU11において、無効割込処理が起動される。

【0068】図9は、本発明の実施例(6)を示したものであって、図8におけると同じものを同じ番号で示し、38はフリップフロップ(FF)、39はバッファである。

12

【0069】割込ベクターのプリフェッチ、CPU11へのベクターの通知方法等は、図8の場合と同様にして行われる。図9の実施例においては、共通バスからの割込信号を、タイマ回路32とCPU11に中継するラッチ31をオン、オフする制御を、フリップフロップ38を介して行い、このフリップフロップ38のセット/リセットを、バッファ39を介してソフトウェアによって行えるようにしている。

【0070】これによって、割込ベクターを受けて割込処理を開始した時点で、ラッチ31をオフにし、割込処理を終了した時点でラッチ31をオンにするように制御すれば、割込が多発した場合には、割込イベントが発生するたびに、調停に参加するCPUの数が減少するので、より厳密に負荷の均等分散を図ることができるようになる。

【0071】図10は、本発明の実施例(7)を示したものであって、図8におけると同じものを同じ番号で示し、40は割込信号を中継するバッファである。

【0072】割込ベクターのプリフェッチ、CPU11へのベクターの通知方法等は、図8の場合と同様にして行われる。図10の実施例においては、CPU11へ割込信号の中継を行うバッファ40の制御を、ラッチ18に有効なベクターがラッチされたときオンにし、その他のときはオフにするようにしておく。

【0073】これによって、CPU11に割込信号が通知されて、CPU11が内部状態をスタック・フレームに退避し、ベクター要求を発生したときには、必ず有効なベクターをCPU11に渡すことができるので、CPU11が無効割込処理を行う必要がなくなり、CPU動作の性能向上を図ることができるようになる。

#### [0074]

【発明の効果】以上説明したように本発明によれば、疎結合型マルチプロセッサ構成をとる装置の各CPUにおいて、CPUがプログラムのどの部分を走行していても、共通バスからの割込信号がCPUに伝達されるのを、蓄積されているキューの数に応じて、ハードウェアによって自律的にコントロールしているので、ある特定のCPUに割込が多数取り込まれることはなく、より負荷が軽いCPUに割込がかかりやすくなっているため、負荷の均等分散を図ることが可能となり、従って負荷分散制御のオーバーヘッドが少ないとともに、この場合のハードウェアの実現規模も小さくてすむ。

【0075】また本発明によれば、CPUに搭載されているソフトウェアの構造のいかんによらず、各CPUは均等にベクターをフェッチすることができる。従って、割込処理はそれぞれのCPUで均等に起動され、負荷の完全分散を行うことが可能となる。

#### 【図面の簡単な説明】

【図1】本発明の原理的構成(1)を示す図である。

【図2】本発明の原理的構成(2)を示す図である。

13

- 【図3】本発明の実施例(1)を示す図である。
- 【図4】本発明の実施例(2)を示す図である。
- 【図5】本発明の実施例(3)を示す図であって、
- (a) は回路構成、(b) はリードオンリーメモリ (R OM) の構成を示す。
- 【図6】ROMの内容の例を示す図である。
- 【図7】本発明の実施例(4)を示す図であって、
- (a) は回路構成、(b) はランダムアクセスメモリ
- (RAM)の構成を示す。
- 【図8】本発明の実施例(5)を示す図である。
- 【図9】本発明の実施例(6)を示す図である。
- 【図10】本発明の実施例(7)を示す図である。
- 【図11】従来の装置構成例を示す図である。

\*【符号の説明】

- 3 共通バス
- 11 CPU
- 15 キュー・カウンタ
- 16 割込伝達制御部
- 17 割込/ベクター・プリフェッチ制御部

14

- 18 ラッチ
- 27 カウンタ
- 28 ROM
- 10 29 RAM
  - 31 ラッチ
  - 40 バッファ

【図1】

本発明の原理的構成(1)を示す図



【図2】

#### 本発明の原理的構成(2)を示す図



[図3]

本発明の実施例(1)を示す図



【図4】

本発明の実施例(2)を示す図



【図6】

## ROMの内容の例を示す図

【図5】

太拳明の家施領(3) を示す図



【図7】

本発明の実施例(4)を示す図



【図8】

本発明の実施例(5)を示す図



【図9】



【図10】

本発明の実施例(7)を示す図



【図11】

